<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Document</title>
    <style>
        h1 {
            font-size: 48px;
        }

        h1 span {
            /* //   内联元素（inline）动画不起作用， 因此要设置为‘inline-block’ */
            display: inline-block;
            animation: jump 500ms ease-in-out;
            animation-delay: var(--delay);
        }

        @keyframes jump {

            0%,
            100% {
                transform: translateY(0);
            }

            50% {
                transform: translateY(-10px);
            }
        }
    </style>
</head>

<body>
    <h1>秦时明月汉时关，万里长征人未还。但使龙城飞将在，不教胡马度阴山。
        <br />
        黄河远上白云间，一片孤城万仞山。羌笛何须怨杨柳，春风不度玉门关。
    </h1>
    <script>
        const h1 = document.querySelector("h1");
        // 包括替换字符串中整个匹配项的副本
        h1.innerHTML = h1.innerText.replace(/\S/g, "<span>$&</span>");

        document.querySelectorAll("span").forEach((span, index) => {
            span.style.setProperty("--delay", `${index * 150}ms`);
        });
    </script>
</body>

</html>